package com.itheima.mapper;

import com.itheima.pojo.Clazz;
import com.itheima.pojo.ClazzQueryParam;
import org.apache.ibatis.annotations.Insert;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Select;

import java.util.List;

@Mapper
public interface ClazzMapper {

    /**
     * 新增班级
     *
     * @param clazz
     */
    @Insert("INSERT INTO clazz (name, room, begin_date, end_date, master_id, subject,create_time,update_time) VALUES (#{name}, #{room}, #{beginDate}, #{endDate}, #{masterId}, #{subject}, #{createTime}, #{updateTime})")
    void insert(Clazz clazz);

    /**
     * 查询所有班级
     *
     * @return
     */
    @Select("SELECT * FROM clazz")
    List<Clazz> selectAll();

    /**
     * 分页查询
     *
     * @param clazzQueryParam
     * @return
     */
    List<Clazz> page(ClazzQueryParam clazzQueryParam);

    /**
     * 根据Id删除班级
     *
     * @param id
     */
    void deleteById(Integer id);

    /**
     * 根据id查询班级
     *
     * @param id
     * @return
     */

    Clazz getById(Integer id);

    /**
     * 修改班级
     *
     * @param clazz
     */

    void update(Clazz clazz);

    /**
     * 查询班级学生人数
     *
     * @param clazzId
     * @return
     */

    int countStudentsByClazzId(Integer clazzId);
}
